<template>
<div style="width: 100%">
  <a-card class="card" :bordered="false">
    <div class="table-page-search-wrapper">
      <a-form layout="vertical">
        <a-row :gutter="48">
          <a-col :sm="{span:12}" :lg="{span:12}" :xl="{span:6}">
            <a-form-item label="准考证号">
              <a-input placeholder="请输入..." v-model="queryParam.ksbmh"/>
            </a-form-item>
          </a-col>
          <a-col :sm="{span:12}" :lg="{span:12}" :xl="{span:6}">
            <a-form-item label="姓名">
              <a-input placeholder="请输入..." v-model="queryParam.ksxm"/>
            </a-form-item>
          </a-col>
          <template v-if="advanced">
          <a-col :sm="{span:12}" :lg="{span:12}" :xl="{span:6}">
            <a-form-item label="招生年度">
              <a-select :allowClear="true" showSearch optionFilterProp="children" v-model="queryParam.zsnj">
                <a-select-option v-for="i in TYPE0126" :key="i.id" :value="i.code">{{ i.name }}</a-select-option>
              </a-select>
            </a-form-item>
          </a-col>
          <a-col :sm="{span:12}" :lg="{span:12}" :xl="{span:6}" >
            <a-form-item label="院系">
              <a-select :allowClear="true" showSearch optionFilterProp="children" v-model="queryParam.bkyxsm" @change="yxChange">
                <a-select-option v-for="i in selectMenu.yx" :key="i.id" :value="i.dwh">{{ i.dwh+'-'+i.dwmc }}</a-select-option>
              </a-select>
            </a-form-item>
          </a-col>
          <a-col :sm="{span:12}" :lg="{span:12}" :xl="{span:6}">
            <a-form-item label="专业">
              <a-select :allowClear="true" showSearch optionFilterProp="children" v-model="queryParam.bkzydm">
                <a-select-option v-for="i in selectMenu.zy" :key="i.id" :value="i.zyh">{{ i.zyh+'-'+i.zymc }}</a-select-option>
              </a-select>
            </a-form-item>
          </a-col>
          <a-col :sm="{span:12}" :lg="{span:12}" :xl="{span:6}">
            <a-form-item label="数据排序方式">
              <a-select :allowClear="true" showSearch optionFilterProp="children" v-model="queryParam.sjpx">
                <a-select-option key="01" value="01">默认排序</a-select-option>
                <a-select-option key="02" value="02">定向在前</a-select-option>
                <a-select-option key="03" value="03">非定向在前</a-select-option>
              </a-select>
            </a-form-item>
          </a-col>
          </template>
          <a-col :sm="{span:20}" :xl="{span:10}" style="padding-top: 29px;">
            <a-button type="primary" @click="loadData">查询</a-button>
            <a-button type="primary" @click="handleExport">导出</a-button>
            <a-button type="primary" @click="handleBatchAudit">批量审核</a-button>
            <a @click="advanced = !advanced" style="margin-left: 8px">
                {{ advanced ? '收起' : '展开' }}
                <a-icon :type="advanced ? 'up' : 'down'"/>
              </a>
          </a-col>
        </a-row>
      </a-form>
    </div>
    </a-card>
    <a-card class="card" :bordered="false">
    <a-table
      ref="table"
      size="default"
      rowKey="key"
      :columns="columns"
      :loading="loading"
      :dataSource="data"
      :alert="options.alert"
      :rowSelection="{selectedRowKeys: selectedRowKeys, onChange: onSelectChange}"
      :pagination="pagination"
      :scroll="{ x: 1500 }"
      @change="handleTableChange"
    >
    <template slot="action" slot-scope="text,record">
        <a @click="handleAudit(record.id)">审核</a>
      </template>
      <span slot="serial" slot-scope="text, record, index">
        {{ index + 1 }}
      </span>
    </a-table>

      <!-- 审核 -->
      <audit-handle :AuditHandleVisible="AuditHandleVisible" @quit="handleCloseAudit" @success="handleSubmitAudit" :info="auitData"></audit-handle>

    </a-card>
</div>
</template>

<script>
// import moment from 'moment'
import AuditHandle from './auditHandle'
import { STable } from '~'
import { mapState } from 'vuex'

const selectArr = ['TYPE0126']

export default {
  components: {
    STable,
    AuditHandle
  },
  data () {
    return {
      advanced: true,
      AuditHandleVisible: false,
      loading: false,
      data: [],
      auitData:'',
      selectedRowKeys: [],
      selectedRows:'',
      pagination:{
        current:1
      },
      // 查询参数
      queryParam: {
       zsnj:'',
       bkyxsm:''
      },
      postParams: {},
      // 表头
      columns: [
        {
          title: '序号',
          scopedSlots: { customRender: 'serial' }
        },
        {
          title: '准考证号',
          dataIndex: 'ksbh'
        },
        {
          title: '姓名',
          dataIndex: 'ksxm'
        },
        {
          title: '录取院系',
          dataIndex: 'bkyxsmc'
        },
        {
          title: '录取专业代码',
          dataIndex: 'lqzym'
        },
        {
          title: '录取专业',
          dataIndex: 'zymc'
        },
        {
          title: '研究方向',
          dataIndex: 'yjfxmc'
        },
        {
          title: '录取导师',
          dataIndex: 'lqdsxm'
        },
        {
          title: '培养模式',
          dataIndex: 'pymsm'
        },
        {
          title: '录取类别',
          dataIndex: 'lqlbm'
        },
        {
          title: '录取状态',
          dataIndex: 'lqzt'
        },
        {
          title: '操作',
          dataIndex: 'cz',
          fixed: 'right',
          width: 120,
          scopedSlots: { customRender: 'action' }
        }
      ],
      // custom table alert & rowSelection
      options: {
        alert: { show: false },
        rowSelection: {
          onChange: (selectedRowKeys, selectedRows) => {
            console.log(`selectedRowKeys: ${selectedRowKeys}`, 'selectedRows: ', selectedRows)
          },
          onSelect: (record, selected, selectedRows) => {
            console.log(record, selected, selectedRows)
          },
          onSelectAll: (selected, selectedRows, changeRows) => {
            console.log(selected, selectedRows, changeRows)
          }
        }
      },
      selectMenu: {
        yx: [], // 院系
        sort:[]

      },
      recruitEditData: {}
    }
  },
  computed: {
    ...mapState({
      systemInfo: state => state.app.systemInfo,
      TYPE0126: state => state.app['TYPE0126'] // 年级
    })
  },
  created () {
    this.initSelectMenu()
    selectArr.forEach(v => {
      this.$store.dispatch('app/setDictionary', v)
    })
  },
  methods: {
    initSelectMenu () {
      let allRequest = [
        this.$api.base.collegeAll()
      ]
      Promise.all(allRequest).then(res => {
        this.selectMenu = {
          yx: res[0].data
        }
        this.$set(this.queryParam,'bkyxsm',res[0].data[0].dwh)
        console.log(this.queryParam.bkyxsm)
        // this.queryParam.bkyxsm=res[0].data[0].dwh
         this.$api.base.majorAll({lsdwh: this.queryParam.bkyxsm}).then(res => {
        this.$set(this.selectMenu, 'zy', res.data)
         })
         this.$api.base.getSchoolYear().then(res=>{
        this.queryParam.zsnj=res.data.doctoralAdmissionYear
        this.loadData({
        pageNum:1,
        pageSize:10
        })
       })
      })
      this.$api.base.getSort().then(res=>{
        this.$set(this.selectMenu,'sort',res.data)
        console.log(this.selectMenu.sort)
      })
    },
    // 选择院系
    yxChange (code) {
      this.$set(this.queryParam, 'sszym', '')
      this.$set(this.selectMenu,'zy','')
      if(code){
      this.$api.base.majorAll({lsdwh: code}).then(res => {
        this.$set(this.selectMenu, 'zy', res.data)
      })
      }
    },
    // 加载数据
     loadData(parameter = {}) {
       if(!parameter.pageNum){
         this.pagination.current = 1
         parameter.pageNum = 1
       }
      let params = Object.assign(this.queryParam, parameter)
      this.loading = true;
      this.$api.doctorRecruit.examineList(params).then(res => {
        // console.log(res)
         const pagination = { ...this.pagination
        };
        pagination.total = 0
        if (res.data && res.data.total) {
          pagination.total = res.data.total;
        }
        this.data = []
        this.pagination = pagination;
        if (res.data && res.data.rows.length) {
          this.data = res.data.rows;
        }
        this.loading = false;
      })
    },
    // 分页
			handleTableChange(pagination, filters, sorter) {
				console.log(pagination);
				const pager = { ...this.pagination
				};
				pager.current = pagination.current;
				this.pagination = pager;
				this.loadData({
					pageSize: 10,
					pageNum: pagination.current
				});
			},
    // 选择招生年度
    zsndChange () {

    },
    // 导出
    handleExport () {
      this.$export('admissions/bsnlqrymd/lqshexport',this.queryParam)
    },
    // 审核
    handleAudit (data) {
      console.log('审核')
      this.auitData=data;
      this.AuditHandleVisible = true
    },
    onSelectChange (selectedRowKeys,selectedRows) {
      this.selectedRowKeys = selectedRowKeys
      this.selectedRows=selectedRows;
    },
    // 批量审核
    handleBatchAudit () {
      if(this.selectedRowKeys.length==0){
        this.$message.warning("请选择...")
        return false
      }
      let idArr=[];
      this.selectedRows.forEach(item=>{
          idArr.push(item.id)
      })
      let idObj=idArr.join(',')
      console.log(idObj)
      this.auitData=idObj;
      this.AuditHandleVisible = true
    },
    // 保存审核
    handleSubmitAudit (d) {
      this.$message.success('审核成功')
      this.selectedRowKeys=[];
      this.AuditHandleVisible = false
      this.loadData({
        pageNum:this.pagination.current,
        pageSize:10
      })
    },
    // 取消审核
    handleCloseAudit () {
      this.AuditHandleVisible = false
    }
  }
}
</script>

<style lang="less" scoped>
.card{
  margin-bottom: 20px;
}
</style>
